# **MIPS R3000 Instruction Set Summary**

### **MIPS Operands**

| Name                      | Example     | Comments                                                                                                                                                                                                            |  |  |
|---------------------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 32   \$0, \$1, \$2,, \$31 |             | Fast location for data. In MIPS, data must be in registers to perform arithmetic. MIPS register \$0 always equal 0. Register \$1 is reserved for the assembler to handle pseudo instructions and large constants    |  |  |
| memory                    | Memory[4],, | Accessed only by data transfer instructions. MIPS uses byte addresses, so sequential words differ by 4. Memory holds data structures, such as arrays, and spilled registers, such as those saved on procedure calls |  |  |

#### **MIPS Assembler Instructions**

| Category      | Instruction                        | Example             | Meaning                     | Comments                         |
|---------------|------------------------------------|---------------------|-----------------------------|----------------------------------|
|               | add                                | add<br>\$1,\$2,\$3  | \$1 = \$2 + \$3             | 3 operands; exception possible   |
|               | subtract                           | sub<br>\$1,\$2,\$3  | \$1 = \$2 - \$3             | 3 operands; exception possible   |
|               | add immediate                      | addi<br>\$1,\$2,100 | \$1 = \$2 + 100             | + constant; exception possible   |
| Arithmetic    | add unsigned                       | addu<br>\$1,\$2,\$3 | \$1 = \$2 + \$3             | 3 operands; exception possible   |
|               | subtract unsigned                  | subi<br>\$1,\$2,\$3 | \$1 = \$2 - \$3             | 3 operands; exception possible   |
|               | add immediate unsigned             | addi<br>\$1,\$2,100 | \$1 = \$2 + 100             | + constant; exception possible   |
|               | Move from coprocessor register     | mfc0<br>\$1,\$epc   | \$1 = \$epc                 | Used to get of Exception PC      |
|               | and                                | and<br>\$1,\$2,\$3  | \$1 = \$2 & \$3             | 3 register operands; Logical AND |
|               | or                                 | or<br>\$1,\$2,\$3   | \$1 = \$2   \$3             | 3 register operands; Logical OR  |
| Logical       | and immediate                      | and<br>\$1,\$2,100  | \$1 = \$2 & 100             | Logical AND register, constant   |
| Logical       | or immediate                       | or<br>\$1,\$2,100   | \$1 = \$2   100             | Logical OR register, constant    |
|               | shift left logical                 | sll<br>\$1,\$2,10   | \$1 = \$2 << 10             | Shift left by constant           |
|               | shift right logical                | srl<br>\$1,\$2,10   | \$1 = \$2 >> 10             | Shift right by constant          |
|               | load word                          | lw \$1,<br>(100)\$2 | \$1 = Memory[\$2+100]       | Data from memory to register     |
| Data transfer | store word                         | sw \$1,<br>(100)\$2 | Memory[\$2+100] = \$1       | Data from memory to register     |
|               | load upper immediate               | lui \$1,100         | \$1 = 100 * 2 <sup>16</sup> | Load constant in upper 16bits    |
|               | lu/o95 old/locturos/r2000 iso html |                     |                             |                                  |

| Conditional branch | branch on equal                  |                      | if (\$1 == \$2) go to<br>PC+4+100       | Equal test; PC relative branch     |
|--------------------|----------------------------------|----------------------|-----------------------------------------|------------------------------------|
|                    | branch on not equal              | bne<br>\$1,\$2,100   | if (\$1 != \$2) go to<br>PC+4+100       | Not equal test; PC relative        |
|                    | set on less than                 | slt<br>\$1,\$2,\$3   | if (\$2 < \$3) \$1 = 1; else<br>\$1 = 0 | Compare less than; 2's complement  |
|                    | set less than immediate          | slti<br>\$1,\$2,100  | if (\$2 < 100) \$1 = 1;<br>else \$1 = 0 | Compare < constant; 2`s complement |
|                    | set less than unsigned           | sltu<br>\$1,\$2,\$3  | if (\$2 < \$3) \$1 = 1; else<br>\$1 = 0 | Compare less than; natural number  |
|                    | set less than immediate unsigned | sltiu<br>\$1,\$2,100 | if (\$2 < 100) \$1 = 1;<br>else \$1 = 0 | Compare constant; natural number   |
|                    | jump                             | j 10000              | goto 10000                              | Jump to target address             |
| Unconditional      | jump register                    | j \$31               | goto \$31                               | For switch, procedure return       |
| jump               | jump and link                    | jal 10000            | \$31 = PC + 4;go to<br>10000            | For procedure call                 |

## **MIPS Floating-Point Operands**

| Name                                  | Example                  | Comments                                                                                                                                                                                                                     |  |  |
|---------------------------------------|--------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 32<br>floating-<br>point<br>registers | \$f0, \$f1, \$f2,, \$f31 | MIPS floating point register are used in pairs for double precision numbers. Odd numbered registers cannot be used for arithemetic or branch, just for data transfer of the right "half" of double precision register pairs. |  |  |
| memory                                | Memory[4],,              | Accessed only by data transfer instructions. MIPS uses byte addresses, so sequential words differ by 4. Memory holds data structures, such as arrays, and spilled registers, such as those saved on procedure calls          |  |  |

## **MIPS Floating-Point Instructions**

| Category   | Instruction             | Example                  | Meaning            | Comments                                   |
|------------|-------------------------|--------------------------|--------------------|--------------------------------------------|
|            | FP add single           | add.s<br>\$f2,\$f4,\$f6  | f2 = f4 + f6       | Floating-Point add (single precision)      |
|            | FP subtract single      | sub.s<br>\$f2,\$f4,\$f6  | \$f2 = \$f4 - \$f6 | Floating-Point sub (single precision)      |
|            | FP multiply single      | mul.s<br>\$f2,\$f4,\$f6  | \$f2 = \$f4 * \$f6 | Floating-Point multiply (single precision) |
| Arithmetic | FP divide single        | div.s<br>\$f2,\$f4,\$f6  | \$f2 = \$f4 / \$f6 | Floating-Point divide (single precision)   |
| Arrumicuc  | FP add double           | add.d<br>\$f2,\$f4,\$f6  | f2 = f4 + f6       | Floating-Point add (double precision)      |
|            | FP.dubtract double      | .dub.d<br>\$f2,\$f4,\$f6 | \$f2 = \$f4 - \$f6 | Floating-Point sub (double precision)      |
|            | FP multiply double      | mul.d<br>\$f2,\$f4,\$f6  | \$f2 = \$f4 * \$f6 | Floating-Point multiply (double precision) |
|            |                         | div.d<br>\$f2,\$f4,\$f6  | \$f2 = \$f4 / \$f6 | Floating-Point divide (double precision)   |
| Data       | load word coprocessor 1 | lwc1                     | \$f1 =             | 32-bit data to FP register                 |

|     | transfer   |                                       | \$f1,100(\$2)         | Memory[\$2+100]           |                                                   |
|-----|------------|---------------------------------------|-----------------------|---------------------------|---------------------------------------------------|
|     |            | store word coprocessor                | swc1<br>\$f1,100(\$2) | Memory[\$2+100] =<br>\$f1 | 32-bit data to memory                             |
|     |            | branch on FP true                     | bc1t 100              | \ / U                     | PC relative branch if FP condition                |
| Ari | Arithmetic | branch on FP false                    | bc1f 100              | \ / \                     | PC relative branch if not condition               |
|     |            | FP compare single (eq,ne,lt,le,gt,ge) | c.lt.s<br>\$f2,\$f4   | `                         | Floating-point compare less than single precision |
|     |            | FP compare double (eq,ne,lt,le,gt,ge) | c.lt.d<br>\$f2,\$f4   |                           | Floating-point compare less than double precision |